Process Analysis Tradeoff Tool (PATT). 
Typical inputs to PATT models include 
industry-average values of product size 
(expressed as number of lines of code), 
productivity (number of lines of code per 
hour) , and number of defects per source 
line of code. The user provides the num- 
ber of resources, the overall percent of ef- 
fort that should be allocated to each 
process step, and the number of desired 
staff members for each step. The output 
of PATT includes the size of the product, 
a measure of effort, a measure of rework 
effort, the duration of the entire process, 


and the numbers of injected, detected, 
and corrected defects as well as a number 
of other interesting features. 

In the development of the present 
model, steps were added to the IEEE 
12207 waterfall process, and this model 
and its implementing software were 
made to run repeatedly through the se- 
quence of steps, each repetition repre- 
senting an iteration in a spiral process. 
Because the IEEE 12207 model is 
founded on a waterfall paradigm, it en- 
ables direct comparison of spiral and 
waterfall processes. The model can be 


used throughout a software-develop- 
ment project to analyze the project as 
more information becomes available. 
For instance, data from early iterations 
can be used as inputs to the model, and 
the model can be used to estimate the 
time and cost of carrying the project to 
completion. 

This work was done by Carolyn Mizell of 
Kennedy Space Center, Charles Curley of 
ASRC Aerospace Corp., and Umanath 
Nayak of Portland State University. Further 
information is contained in a TSP (see page 
1). KSC-13094 


©Algorithm That Synthesizes Other Algorithms for Hashing 

A synthesized algorithm is guaranteed to be executable in constant time. 

NASA’s Jet Propulsion Laboratory, Pasadena, California 


An algorithm that includes a collec- 
tion of several subalgorithms has been 
devised as a means of synthesizing still 
other algorithms (which could include 
computer code) that utilize hashing to 
determine whether an element (typi- 
cally, a number or other datum) is a 
member of a set (typically, a list of num- 
bers). Each subalgorithm synthesizes an 
algorithm (e.g., a block of code) that 
maps a static set of key hashes to a some- 
what linear monotonically increasing se- 
quence of integers. The goal in formu- 
lating this mapping is to cause the 
length of the sequence thus generated 
to be as close as practicable to the origi- 
nal length of the set and thus to mini- 
mize gaps between the elements. 

The advantage of the approach em- 
bodied in this algorithm is that it com- 
pletely avoids the traditional approach 


of hash-key look-ups that involve either 
secondary hash generation and look-up 
or further searching of a hash table for a 
desired key in the event of collisions. 

This algorithm guarantees that it will 
never be necessary to perform a search 
or to generate a secondary key in order 
to determine whether an element is a 
member of a set. This algorithm fur- 
ther guarantees that any algorithm that 
it synthesizes can be executed in con- 
stant time. To enforce these guaran- 
tees, the subalgorithms are formulated 
to employ a set of techniques, each of 
which works very effectively covering a 
certain class of hash-key values. These 
subalgorithms are of two types, summa- 
rized as follows: 

• Given a list of numbers, try to find one 
or more solutions in which, if each 
number is shifted to the right by a con- 


stant number of bits and then masked 
with a rotating mask that isolates a set 
of bits, a unique number is thereby 
generated. In a variant of the forego- 
ing procedure, omit the masking. Try 
various combinations of shifting, mask- 
ing, and/or offsets until the solutions 
are found. From the set of solutions, 
select the one that provides the great- 
est compression for the representation 
and is executable in the minimum 
amount of time. 

• Given a list of numbers, try to find one 
or more solutions in which, if each 
number is compressed by use of the 
modulo function by some value, then a 
unique value is generated. 

This work was done by Mark James for Cal- 
tech for NASA’s Jet Propulsion Laboratory. 
Further information is contained in a TSP 
(see page 1 ). NPO-451 75 


©Algorithms for High-Speed Noninvasive Eye-Tracking System 

One of the algorithms enables tracking at a frame rate of several kilohertz. 

NASA’s Jet Propulsion Laboratory, Pasadena, California 


Two image-data-processing algo- 
rithms are essential to the successful op- 
eration of a system of electronic hard- 
ware and software that noninvasively 
tracks the direction of a person’s gaze in 
real time. The system was described in 
“High-Speed Noninvasive Eye-Tracking 
System” (NPO-30700) NASA Tech Briefs, 
Vol. 31, No. 8 (August 2007), page 51. 

To recapitulate from the cited article: 
Like prior commercial noninvasive eye- 


tracking systems, this system is based on 
(1) illumination of an eye by a low- 
power infrared light-emitting diode 
(LED); (2) acquisition of video images 
of the pupil, iris, and cornea in the re- 
flected infrared light; (3) digitization of 
the images; and (4) processing the digi- 
tal image data to determine the direc- 
tion of gaze from the centroids of the 
pupil and cornea in the images. Most of 
the prior commercial noninvasive eye- 


tracking systems rely on standard video 
cameras, which operate at frame rates of 
about 30 Hz. Such systems are limited to 
slow, full-frame operation. 

The video camera in the present sys- 
tem includes a charge-coupled-device 
(CCD) image detector plus electronic cir- 
cuitry capable of implementing an ad- 
vanced control scheme that effects read- 
out from a small region of interest (ROI) , 
or subwindow, of the full image. Inas- 
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